home *** CD-ROM | disk | FTP | other *** search
/ Cream of the Crop 26 / Cream of the Crop 26.iso / os2 / octa209s.zip / octave-2.09 / liboctave / CmplxDET.cc < prev    next >
C/C++ Source or Header  |  1996-03-03  |  1KB  |  72 lines

  1. /*
  2.  
  3. Copyright (C) 1996 John W. Eaton
  4.  
  5. This file is part of Octave.
  6.  
  7. Octave is free software; you can redistribute it and/or modify it
  8. under the terms of the GNU General Public License as published by the
  9. Free Software Foundation; either version 2, or (at your option) any
  10. later version.
  11.  
  12. Octave is distributed in the hope that it will be useful, but WITHOUT
  13. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  14. FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  15. for more details.
  16.  
  17. You should have received a copy of the GNU General Public License
  18. along with Octave; see the file COPYING.  If not, write to the Free
  19. Software Foundation, 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
  20.  
  21. */
  22.  
  23. #if defined (__GNUG__)
  24. #pragma implementation
  25. #endif
  26.  
  27. #ifdef HAVE_CONFIG_H
  28. #include <config.h>
  29. #endif
  30.  
  31. #include <cfloat>
  32. #include <cmath>
  33.  
  34. #include "CmplxDET.h"
  35. #include "oct-cmplx.h"
  36.  
  37. int
  38. ComplexDET::value_will_overflow (void) const
  39. {
  40.   return det[2].real () + 1 > log10 (DBL_MAX) ? 1 : 0;
  41. }
  42.  
  43. int
  44. ComplexDET::value_will_underflow (void) const
  45. {
  46.   return det[2].real () - 1 < log10 (DBL_MIN) ? 1 : 0;
  47. }
  48.  
  49. Complex
  50. ComplexDET::coefficient (void) const
  51. {
  52.   return det[0];
  53. }
  54.  
  55. int
  56. ComplexDET::exponent (void) const
  57. {
  58.   return (int) (det[1].real ());
  59. }
  60.  
  61. Complex
  62. ComplexDET::value (void) const
  63. {
  64.   return det[0] * pow (10.0, det[1].real ());
  65. }
  66.  
  67. /*
  68. ;;; Local Variables: ***
  69. ;;; mode: C++ ***
  70. ;;; End: ***
  71. */
  72.